import { Form, Input, Button, Checkbox, Card, message } from 'antd'
import logo from '@/assets/logo.png'
import { useDispatch } from 'react-redux'
import './index.scss'
import { getLogin } from '@/store/actions'
import { useHistory } from 'react-router'

const Login = () => {
  const rules = {
    mobile: [
      {
        pattern: /^1[3-9]\d{9}$/,
        message: '手机号码格式不正确',
        // validateTrigger: 'onBlur',
      },
      {
        required: true,
        message: '请输入手机号',
        // validateTrigger: ['onBlur', 'onChange'],
      },
    ],
    code: [
      {
        len: 6,
        message: '验证码为6个字符',
        // validateTrigger: ['onBlur', 'onChange'],
      },
      { required: true, message: '请输入验证码' },
    ],
  }
  const dispatch = useDispatch()
  const history = useHistory()
  const onFinish = async (value) => {
    try {
      await dispatch(getLogin(value))
      history.replace('/home')
    } catch (e) {
      message.warning('出了点小问题')
    }
  }
  return (
    <div className="login">
      <Card
        className="login-container"
        bordered={false}
        bodyStyle={{
          padding: 20,
        }}
      >
        <img className="login-logo" src={logo} alt="" />
        <Form
          validateTrigger={['onBlur', 'onChange']}
          onFinish={onFinish}
          initialValues={{
            mobile: '13911111111',
            code: '246810',
            remeber: true,
          }}
        >
          <Form.Item name="mobile" rules={rules.mobile}>
            <Input size="large" placeholder="请输入手机号" maxLength={11} />
          </Form.Item>
          <Form.Item name="code" rules={rules.code}>
            <Input size="large" placeholder="请输入验证码" maxLength={6} />
          </Form.Item>
          <Form.Item name="remember" valuePropName="checked">
            <Checkbox className="login-checkbox-label">
              我已阅读并同意「用户协议」和「隐私条款」
            </Checkbox>
          </Form.Item>

          <Form.Item>
            <Button type="primary" htmlType="submit" size="large" block>
              登录
            </Button>
          </Form.Item>
        </Form>
      </Card>
    </div>
  )
}

export default Login
